<template>
  <view class="wrap">
    <scroll-view
      :scroll-top="state.scrollTop"
      scroll-y="true"
      class="scroll-Y scroll"
      @scroll="scroll"
      id="view1"
    >
      <view>
        <view class="header headerName">
          <img class="img" src="https://ainengli.hzjrsw.com/jkhx/knowledgeBg.png" alt="" />
          <view class="title">关于尿酸</view>
          <view class="subtitle">了解健康知识，我的健康我做主</view>
        </view>
        <scroll-view :class="['scroll-X', state.scrollActive == true ? 'on' : '']" scroll-x="true">
          <view class="tabList">
            <view
              :class="['item', state.tabActive == index ? 'on' : '']"
              v-for="(item, index) in state.tabList"
              :key="index"
              @tap="tabFun(index)"
            >
              <text class="text">{{ item.name }}</text>
              <text class="text" />
            </view>
          </view>
        </scroll-view>
        <view class="content itemName itemName1">
          <view class="title">
            <text class="name">概述</text>
            <img class="img" src="https://ainengli.hzjrsw.com/jkhx/common/title-bg-row.png" alt="" />
          </view>
          <text class="content-item">
            尿酸是人体嘌呤代谢的终产物。人体内的嘌呤主要来自食物摄入和自身合成，嘌呤在经过一系列代谢过程后，最终生成尿酸。尿酸主要通过肾脏排泄出体外。
          </text>
        </view>
        <view class="content itemName itemName2">
          <view class="title">
            <text class="name">正常范围</text>
            <img class="img" src="https://ainengli.hzjrsw.com/jkhx/common/title-bg-row.png" alt="" />
          </view>
          <view class="table-box">
            <view class="rows">
              <view class="rows-item rows-header">人群</view>
              <view class="rows-item rows-header">正常</view>
            </view>
            <view class="rows">
              <view class="rows-item">男性</view>
              <view class="rows-item">150-416μmol/L</view>
            </view>
            <view class="rows">
              <view class="rows-item">女性</view>
              <view class="rows-item">89-357μmol/L</view>
            </view>
          </view>
          <text class="content-item">
            但是不同实验室检测方法数值可能不同，不同检测单位也会对试验结果造成影响。
          </text>
        </view>
        <view class="content itemName itemName3">
          <view class="title">
            <text class="name">异常范围</text>
            <img class="img" src="https://ainengli.hzjrsw.com/jkhx/common/title-bg-row.png" alt="" />
          </view>
          <view class="table-box">
            <view class="rows">
              <view class="rows-item rows-header">人群</view>
              <view class="rows-item rows-header">偏低</view>
              <view class="rows-item rows-header">偏高</view>
            </view>
            <view class="rows">
              <view class="rows-item">男性</view>
              <view class="rows-item">{{ '＜150μmol/L' }}</view>
              <view class="rows-item">{{ '＞416μmol/L' }}</view>
            </view>
            <view class="rows">
              <view class="rows-item">女性</view>
              <view class="rows-item">{{ '＜89μmol/L' }}</view>
              <view class="rows-item">{{ '＞357μmol/L' }}</view>
            </view>
          </view>
          <view class="table-box" style="margin-top: 24rpx">
            <view class="rows">
              <view class="rows-item rows-header" style="width: 390rpx">影响因素</view>
              <view class="rows-item">尿酸偏高</view>
              <view class="rows-item">尿酸偏低</view>
            </view>
            <view class="rows">
              <view class="rows-item rows-header" style="width: 390rpx">生理性因素</view>
              <view class="rows-item">
                <text> 1.在检测尿酸前进食了大量的高嘌呤饮食 </text>
                <text> 2.剧烈运动后会导致大量肌肉的ATP分解，嘌呤生成增多 </text>
              </view>
              <view class="rows-item">长时间进食减少，外源性摄入的嘌呤减少</view>
            </view>
            <view class="rows">
              <view class="rows-item rows-header" style="width: 390rpx">病理性因素</view>
              <view class="rows-item">
                <text>1.单纯高尿酸血症</text>
                <text>2.痛风</text>
                <text>3.肾炎等疾病</text>
              </view>
              <view class="rows-item">大剂量的糖皮质激素、维生素C</view>
            </view>
            <view class="rows">
              <view class="rows-item rows-header" style="width: 390rpx">疾病因素</view>
              <view class="rows-item">/</view>
              <view class="rows-item">肝坏死、肝豆状核变性</view>
            </view>
          </view>
        </view>
        <view class="content itemName itemName4">
          <view class="title">
            <text class="name">就医指征</text>
            <img class="img" src="https://ainengli.hzjrsw.com/jkhx/common/title-bg-row.png" alt="" />
          </view>
          <text class="content-item"
            >（1）尿酸偏高需要警惕痛风、肾炎，需要及时去医院就诊，完善检查。可能涉及到的有尿素氮、肌酐、肾脏彩超等检查。尤其是当尿酸超过600μmol/L的时候，服药降低
            尿酸是必须的。
          </text>
          <text class="content-item">
            （2）尿酸偏低：
            1.生理性因素：检测出尿酸减低。检查前三天有饮食减少、服用糖皮质激素、维生素C的情况，需停药至少3天后复查，若是复查结果正常则不需要特殊处理。
            2.尿酸低于80μmol/L，排除了上述生理性因素。可能存在尿酸合成不足、或者嘌呤代谢障碍。需要警惕肝坏死以及肝豆状核变性这些肝脏疾病。患者可能出现乏力、黄疸、厌食、严重的可能出现昏迷等症状，需要及时就医。
          </text>
          <text class="content-item"> 就诊科室: 内分泌科、肾内科 </text>
        </view>
        <view class="content itemName itemName5">
          <view class="title">
            <text class="name">日常生活建议</text>
            <img class="img" src="https://ainengli.hzjrsw.com/jkhx/common/title-bg-row.png" alt="" />
          </view>
          <text class="content-item">（1）尿酸偏高</text>
          <text class="content-item"
            >1.避免高嘌呤饮食：高嘌呤饮食应该避免，常见的有火锅、海鲜、动物内脏等。
          </text>
          <text class="content-item"
            >2.戒酒：由于酒精对尿酸的代谢与生成作用十分复杂，为了维持人体内尿酸的稳定，戒酒是必须要做的。
          </text>
          <text class="content-item"
            >3.多水：为了促进尿酸的排泄，患者需要大量饮水，建议每日的饮水量在2000ml以 上。
          </text>
          <text class="content-item"
            >4.禁止剧烈运动，但是规律适当且舒缓的运动对疾病的恢复是有一定的好处，例如游泳、慢走、太极等。
          </text>
          <text class="content-item">（2）尿酸偏低 </text>
          <text class="content-item"
            >1.饮食：尽量均衡饮食，避免饮食不规律，以及长时间不进食。
          </text>
          <text class="content-item"
            >2.注意用药安全：糖皮质激素、维生素C等药物会影响尿酸的代谢，引起偏低。
          </text>
        </view>
        <view class="content itemName itemName6">
          <view class="title">
            <text class="name">参考文献</text>
            <img class="img" src="https://ainengli.hzjrsw.com/jkhx/common/title-bg-row.png" alt="" />
          </view>
          <text class="content-item"
            >[1]万学红，卢雪峰编.诊断学(第九版)[M].北京:人民卫生出版社出版社,2018.347- 348.
          </text>
          <text class="content-item"
            >[2]潘祥林，王鸿利.实用诊断学第2版[M].北京:人民卫生出版社出版社,2017.824
          </text>
          <text class="content-item"
            >[3]陆金春，张红烨，骆峻.医学检验报告速查手册[M].北京:东南大学出版社,2019.68
          </text>
          <text class="content-item"
            >[4]葛均波，徐永健.内科学[M].9版.北京:人民卫生出版社，2018:783-786
          </text>
          <text class="content-item"
            >[5]国家食品药品监督管理总局执业药师资格认证中心组织编写.药学综合知识与技能第7版[M].北京:中国医药科技出版社,2018.01.152.
          </text>
        </view>
      </view>
    </scroll-view>
  </view>
</template>

<script setup lang="ts">
import { ref, reactive, nextTick } from 'vue'
import { onLoad, onUnload, onShow } from '@dcloudio/uni-app'
const state = reactive({
  tabList: [
    { name: '概述' },
    { name: '正常范围' },
    { name: '异常范围' },
    { name: '就医指征' },
    { name: '日常生活建议' },
    { name: '参考文献' }
  ],
  scrollActive: false,
  tabActive: 0,
  title: '',
  type: '',
  scrollTop: 0
})

const distanceArr = ref([])

onShow(() => {
  nextTick(() => {
    getDistanceArr()
  })
})

// 获取所有元素在当前页面所处的位置信息
const getDistanceArr = () => {
  uni
    .createSelectorQuery()
    .select('.itemName1')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()

  uni
    .createSelectorQuery()
    .select('.itemName2')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()
  uni
    .createSelectorQuery()
    .select('.itemName3')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()
  uni
    .createSelectorQuery()
    .select('.itemName4')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()

  uni
    .createSelectorQuery()
    .select('.itemName5')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()
  uni
    .createSelectorQuery()
    .select('.itemName6')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()
  uni
    .createSelectorQuery()
    .select('.itemName7')
    .boundingClientRect((res) => {
      distanceArr.value.push(res.top)
    })
    .exec()
}

const tabFun = (index) => {
  // 方法一 简单一点直接跳转到id对应的位置
  nextTick(() => {
    if (index == 0) {
      state.scrollTop = 0
      state.tabActive = 0
    } else {
      state.tabActive = index
      if (uni.getSystemInfoSync().uniPlatform == 'mp-weixin') {
        state.scrollTop = distanceArr.value[index] - 105
      } else {
        state.scrollTop = distanceArr.value[index] - 65
      }
    }
    const timer = setTimeout(() => {
      clearTimeout(timer)
    }, 500) // 解决ios和安卓、鸿蒙系统兼容性问题
  })
}
const scroll = (e) => {
  const skewY = 170 // 偏移量，由于吸顶的tab、头部的显示信息也有高度，素以做了偏移量
  if (e.detail.scrollTop >= skewY) {
    if (!state.scrollActive && state.tabActive <= 0) {
      // 在未显示tab并且 currentTab <= 0时，防止uview ui抖动bug，设置默认复位值
      state.tabActive = 0
    }
    state.scrollActive = true

    nextTick(() => {
      const length = distanceArr.value.length
      const index = distanceArr.value.findIndex((el) => el - skewY - e.detail.scrollTop > 0)
      // 当index  == -1 的时候，实际当前滚动的距离超出了最大值，也就是在最后一个tab显示的内容
      // 当index > 0 的时候，说明能在当前的scrollTop值找到，即index的前一位
      if (e.detail.scrollTop + 600 > distanceArr.value[length - 1]) {
        return
      } else {
        state.tabActive = index > 0 ? index - 1 : length - 1
      }
    })
  } else {
    state.scrollActive = false
  }
}
</script>

<style lang="scss" scoped>
.wrap {
  .header {
    position: relative;
    display: inline-block;
    width: calc(100% - 64rpx);
    height: 180rpx;
    margin: 32rpx 32rpx 0;

    .img {
      position: absolute;
      top: 0;
      width: 100%;
      height: 100%;
    }

    .title {
      position: relative;
      z-index: 1;
      margin: 30rpx 40rpx 20rpx;
      font-size: 40rpx;
      font-weight: 700;
      color: #fff;
    }

    .subtitle {
      position: relative;
      z-index: 1;
      margin: 0 40rpx;
      font-size: 28rpx;
      color: #fff;
    }
  }

  .scroll-Y {
    box-sizing: border-box;
    height: 100vh;
    padding-bottom: calc(30rpx + constant(safe-area-inset-bottom));
    padding-bottom: calc(30rpx + env(safe-area-inset-bottom));
  }

  .scroll-X {
    width: calc(100% - 64rpx);
    margin: 30rpx 32rpx 0;
    overflow-x: scroll;
    background: #f3f7f8;

    &.on {
      position: fixed;
      top: 0;
      left: 0;
      z-index: 9999;
      display: block;
      width: 100%;
      padding: 30rpx 0;
      margin: 0;

      .tabList {
        padding: 0 16rpx;
      }
    }

    .tabList {
      white-space: nowrap;

      .item {
        position: relative;
        display: inline-block;
        height: 64rpx;
        padding: 0 30rpx;
        margin-right: 32rpx;
        font-size: 28rpx;
        line-height: 64rpx;
        color: #222;
        text-align: center;
        vertical-align: middle;
        background: #fff;
        border-radius: 32rpx;

        &:nth-last-child(1) {
          margin-right: 0;
        }

        &.on {
          font-weight: 700;
          color: #fff;
          background: #00d1b6;
        }
      }
    }
  }

  .content {
    padding: 32rpx;
    margin: 30rpx 32rpx 0;
    background: #fff;
    border-radius: 16rpx;

    .title {
      position: relative;
      margin-bottom: 20rpx;

      .name {
        position: relative;
        z-index: 1;
        font-size: 34rpx;
        font-weight: 700;
        color: #222;
      }

      .img {
        position: absolute;
        bottom: 0;
        left: 0;
        display: block;
        width: 40rpx;
        height: 12rpx;
      }
    }

    .content-item {
      display: block;
      margin-top: 20rpx;
      font-size: 30rpx;
      line-height: 1.6;
      color: #222;
      text-align: justify;
    }

    .define {
      padding: 10px 0 10px 10px;
      margin: 20px 0 10px;
      font-size: 32rpx;
      font-weight: 700;
      background: linear-gradient(90deg, rgb(2 188 195 / 5%) 0%, rgb(2 188 195 / 0%) 100%);
      border-radius: 4px;
    }

    .itemName {
      margin-bottom: 40rpx;
    }

    .itemName:last-child {
      margin-bottom: 0;
    }
  }
}

.table-box {
  width: 100%;
  border: 1rpx solid #cce4e1;

  .rows {
    display: flex;
    font-size: 28rpx;

    .rows-item {
      display: flex;
      flex-direction: column;
      justify-content: center;
      // align-items: center;
      width: 100%;
      padding: 24rpx 16rpx;
      font-size: 28rpx;
      color: #222;
      border-right: 1rpx solid #cce4e1;
      // font-weight: 400;
      border-bottom: 1rpx solid #cce4e1;
    }

    .rows-item:last-child {
      border-right-width: 0rpx;
    }

    .rows-header {
      font-weight: 600;
      color: #00d1b6;
      background: rgb(0 209 182 / 5%);
    }
  }

  .rows:last-child {
    .rows-item {
      border-bottom-width: 0rpx;
    }
  }
}
</style>
